
CLAIMS 

What is claimed is: 

1 1. A content addressable memory (CAM) system 

2 comprising: 

3 a ternary CAM array segmented into a plurality of 

4 array groups, each array group including a plurality of 

5 rows of ternary CAM cells; and 

6 a plurality of first storage elements each for 

7 storing a priority of a corresponding array group. 

1 2. The CAM system of Claim 1, wherein two or more 

f .s 

q 2 array groups have the same priority. 

□ 

ill 

Ull 3. The CAM system of Claim 1, wherein one of the rows 

Q 

IB 2 of ternary CAM cells comprises: 

CO 3 a plurality of CAM cells for storing a data word; 

□ 4 and 

U 

~, 5 a plurality of mask cells for storing a local mask 

RJ 6 word . 

w 

1 4 . The CAM system of Claim 3 , wherein each data word 

2 comprises a policy statement. 

1 5. The CAM system of Claim 4, wherein the policy 

2 statement comprises protocol information. 

1 6. The CAM system of Claim 4, wherein the policy 

2 statement comprises type-of -service information. 

1 7. The CAM system of Claim 4, wherein the policy 

2 statement comprises cost-of -service information. 
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1 8. The CAM system of Claim 4, wherein each local mask 

2 word includes a policy mask. 

1 9. The CAM system of Claim 1, further comprising a 

2 plurality of second storage elements each for storing a group 

3 valid bit indicating whether an associated array group is 

4 assigned its corresponding priority number. 



1 10. The CAM system of Claim 1, further comprising a 

p 2 priority table including the plurality of first storage 
D 3 elements. 

m 

m 
□ 

5 ~ 1 11. The CAM system of Claim 1, further comprising an 

Of) 2 index circuit coupled to the ternary CAM array to determine 
n 3 the index of a location in the ternary CAM array that stores 

: s 

4 data that matches a search key. 



ru i 

o 

ru 



1 12. The CAM system of Claim 11, wherein the index 

2 circuit comprises: 

3 a select circuit having a plurality of inputs to 

4 receive match signals from the plurality of array 

5 groups, each match signal indicative of a result of a 

6 comparison between the search key and the data stored in 

7 the array groups, and having a plurality of outputs to 

8 provide qualified match signals for the plurality of 

9 array groups; and 

10 a priority encoder having a plurality of inputs to 

11 receive the plurality of qualified match signals, and 
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having an output to provide the index of the highest 
priority location in the ternary CAM array that stores 
data that matches the search key in response to the 
qualified match signals. 

13. The CAM system of Claim 12, wherein the select 
circuit includes means for selectively forcing non-qualified 
match signals to a mismatch state. 

14. The CAM system of Claim 12, wherein the select 
circuit further comprises: 

a plurality of logic gates, each having first 
inputs to receive the match signals from a corresponding 
array group, a second input to receive an enable signal 
for the corresponding array group, and outputs to 
selectively provide the match signals to the priority 
encoder as qualified match signals in response to the 
enable signal; and 

a compare circuit for generating the enable signals 
in response to a comparison between the priorities 
associated with array groups that have data stored that 
matches the search key. 

15. The CAM system of Claim 14, further comprising a 
priority table including the plurality of first storage 
elements . 

16. The CAM system of Claim 15, wherein the select 
circuit further comprises a plurality of group match flag 
circuits, each receiving the match signals from a 
corresponding array group and generating a group match flag 
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in response thereto, wherein the group match flags are 
provided as select signals to corresponding rows of the 
priority table. 

17. The CAM system of Claim 1, further comprising: 
means for storing data in the array groups 

according to priority. 

18. The CAM system of Claim 1, further comprising an 
address circuit coupled to the ternary CAM array to select a 
row of the ternary CAM cells for communicating data. 

19. The CAM system of Claim 18, wherein the address 
circuit comprises an address decoder to select a row in one 
array group corresponding to the priority in response to a 
next free address (NFA) . 

20. The CAM system of Claim 19, wherein the address 
circuit further comprises an NFA table having a number of 
rows, each row for storing the NFA for a corresponding 
priority. 

21. The CAM system of Claim 20, wherein each row in the 
NFA table includes an empty bit storage element for storing 
an empty bit indicative of whether any array group is 
assigned to the corresponding priority. 

22. The CAM system of Claim 9, wherein each of the rows 
of ternary CAM cells includes a valid bit storage element for 
storing a valid bit indicative of whether the corresponding 
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row of ternary CAM cells stores valid data. 

23. The CAM system of Claim 9, further comprising an 
index circuit coupled to the valid bit storage elements to 
determine a next free array address for an array group and 
its associated priority, and further coupled to the plurality 
of second storage elements to determine a next free group 
address for the array group and its associated priority. 



24. The CAM system of Claim 23, wherein the index 
circuit comprises: 

a select circuit having a plurality of inputs to 
receive the valid bits from the plurality of array 
groups, and having a plurality of outputs to provide 
qualified, valid bits for the plurality of array groups; 
and 

a priority encoder having a plurality of inputs to 
receive the plurality of qualified valid bits, and 
having an output to generate the next free array address 
in response to the qualified valid bits. 

25. The CAM system of Claim 24, wherein the select 
circuit includes means for selectively forcing non-qualified 
valid bits to a mismatch state. 

26. The CAM system of Claim 24, wherein the select 
circuit further comprises: 

a plurality of logic gates, each having first 
inputs to receive the valid bits from a corresponding 
array group, a second input to receive an enable signal 
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6 for the corresponding array group, and outputs to 

7 selectively provide the valid bits to the priority 

8 encoder as qualified valid bits in response to the 

9 enable signal; and 

10 a compare circuit for generating the enable signals 

11 in response to a comparison between the priority of the 

12 data and the priorities of the array groups. 



1 27. The CAM system of Claim 24, wherein the index 

2 circuit further comprises: 

3 a group priority encoder having a plurality of 

*** 4 inputs to receive the group valid bits from each of the 

O 

Q 5 plurality of array groups, and having an output to 

yi 

ffjj 6 provide the next free group address . 

Nf 1 

m 

1 28. A method of operating a content addressable memory 

2 (CAM) system including an array of ternary CAM cells 

M= 3 segmented into a plurality of array groups, comprising: 

ffj 

pjj 4 storing a plurality of priorities in a plurality of 

0 5 storage elements each associated with one or more of the 

ru 

6 array groups ; and 

7 selectively storing data in the array groups 

8 according to priorities. 
1 

1 29. The method of Claim 28, wherein the selectively 

2 storing data comprises: 

3 providing a next free address (NFA) of an available 

4 row of ternary CAM cells within an array group 

5 corresponding to one of the priorities; and 

6 storing the data at the NFA. 
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1 30. The method of Claim 29, wherein providing the NFA 

2 comprises: 

3 generating the NFA; 

4 storing the NFA in a corresponding row of an NFA 

5 table; 

6 selecting a row of the NFA table using the 

7 priority; and 

8 accessing the NFA corresponding to the priority. 

1 31. The method of Claim 30, wherein generating the NFA 

2 comprises: 

jpj 3 for each array group, comparing associated 

Q 4 priorities of the data with the priority of the array 

m 

\f % 5 group to generate an enable signal; 

6 selectively allowing, in response to the enable 

00 7 signals, valid bits from corresponding array groups to 

^ 8 participate in the generation of the NFA, the valid bits 

9 indicating whether valid data is stored in corresponding 

m 

fylO rows of each array group. 

6 
ru 

1 32. The method of Claim 31, wherein the selectively 

2 allowing comprises: 

3 selectively qualifying the valid bits from each 

4 array group in response to the corresponding enable 

5 signal to generate qualified valid bits; and 

6 generating the NFA in response to the qualified 

7 valid bits. 

1 33. The method of Claim 31, wherein the generating the 

2 NFA further comprises: 

3 for each array group, storing a group valid bit 
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4 indicative of whether the array group is assigned to one 

5 of the priorities; and 

6 generating a first portion of the NFA in response 

7 to the group valid bits. 
1 

1 34. The method of Claim 28, further comprising: 

2 selectively comparing a search key with data stored 

3 in the array groups . 

1 35. The method of Claim 34, wherein the selectively 

2 comparing comprises: 

■ 3 comparing the search key with data stored in the 

O 4 array groups to generate match signals; 

111 

ypjl 5 comparing the associated priorities of each array 

p 6 group that includes data that matches the search key to 

yj 7 generate a plurality of enable signals; and 

p 8 selectively qualifying the match signals in 

H 9 response to the enable signals to generate qualified 

w 

rylO match signals. 

5 

1 36. The method of Claim 35, further comprising: 

2 generating an index of the highest priority match 

3 (HPM) in response to the qualified match signals. 
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